# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
# RUN: llc -mtriple=amdgcn-amd-amdhsa -mcpu=fiji -run-pass=amdgpu-postlegalizer-combiner -verify-machineinstrs %s -o - | FileCheck %s

---
name: cvt_f32_ubyte0_lshr_0
tracksRegLiveness: true
body:             |
  bb.0:
    liveins: $vgpr0

    ; CHECK-LABEL: name: cvt_f32_ubyte0_lshr_0
    ; CHECK: liveins: $vgpr0
    ; CHECK-NEXT: {{  $}}
    ; CHECK-NEXT: %arg:_(s32) = COPY $vgpr0
    ; CHECK-NEXT: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE0 %arg
    ; CHECK-NEXT: $vgpr0 = COPY %result(s32)
    %arg:_(s32) = COPY $vgpr0
    %shiftamt:_(s32) = G_CONSTANT i32 0
    %shift:_(s32) = G_LSHR %arg, %shiftamt
    %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE0 %shift
    $vgpr0 = COPY %result
...

---
name: cvt_f32_ubyte0_lshr_8
tracksRegLiveness: true
body:             |
  bb.0:
    liveins: $vgpr0

    ; CHECK-LABEL: name: cvt_f32_ubyte0_lshr_8
    ; CHECK: liveins: $vgpr0
    ; CHECK-NEXT: {{  $}}
    ; CHECK-NEXT: %arg:_(s32) = COPY $vgpr0
    ; CHECK-NEXT: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE1 %arg
    ; CHECK-NEXT: $vgpr0 = COPY %result(s32)
    %arg:_(s32) = COPY $vgpr0
    %shiftamt:_(s32) = G_CONSTANT i32 8
    %shift:_(s32) = G_LSHR %arg, %shiftamt
    %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE0 %shift
    $vgpr0 = COPY %result
...

---
name: cvt_f32_ubyte0_lshr_16
tracksRegLiveness: true
body:             |
  bb.0:
    liveins: $vgpr0

    ; CHECK-LABEL: name: cvt_f32_ubyte0_lshr_16
    ; CHECK: liveins: $vgpr0
    ; CHECK-NEXT: {{  $}}
    ; CHECK-NEXT: %arg:_(s32) = COPY $vgpr0
    ; CHECK-NEXT: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE2 %arg
    ; CHECK-NEXT: $vgpr0 = COPY %result(s32)
    %arg:_(s32) = COPY $vgpr0
    %shiftamt:_(s32) = G_CONSTANT i32 16
    %shift:_(s32) = G_LSHR %arg, %shiftamt
    %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE0 %shift
    $vgpr0 = COPY %result
...

---
name: cvt_f32_ubyte0_lshr_24
tracksRegLiveness: true
body:             |
  bb.0:
    liveins: $vgpr0

    ; CHECK-LABEL: name: cvt_f32_ubyte0_lshr_24
    ; CHECK: liveins: $vgpr0
    ; CHECK-NEXT: {{  $}}
    ; CHECK-NEXT: %arg:_(s32) = COPY $vgpr0
    ; CHECK-NEXT: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE3 %arg
    ; CHECK-NEXT: $vgpr0 = COPY %result(s32)
    %arg:_(s32) = COPY $vgpr0
    %shiftamt:_(s32) = G_CONSTANT i32 24
    %shift:_(s32) = G_LSHR %arg, %shiftamt
    %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE0 %shift
    $vgpr0 = COPY %result
...

---
name: cvt_f32_ubyte1_lshr_8
tracksRegLiveness: true
body:             |
  bb.0:
    liveins: $vgpr0

    ; CHECK-LABEL: name: cvt_f32_ubyte1_lshr_8
    ; CHECK: liveins: $vgpr0
    ; CHECK-NEXT: {{  $}}
    ; CHECK-NEXT: %arg:_(s32) = COPY $vgpr0
    ; CHECK-NEXT: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE2 %arg
    ; CHECK-NEXT: $vgpr0 = COPY %result(s32)
    %arg:_(s32) = COPY $vgpr0
    %shiftamt:_(s32) = G_CONSTANT i32 8
    %shift:_(s32) = G_LSHR %arg, %shiftamt
    %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE1 %shift
    $vgpr0 = COPY %result
...

---
name: cvt_f32_ubyte1_lshr_16
tracksRegLiveness: true
body:             |
  bb.0:
    liveins: $vgpr0

    ; CHECK-LABEL: name: cvt_f32_ubyte1_lshr_16
    ; CHECK: liveins: $vgpr0
    ; CHECK-NEXT: {{  $}}
    ; CHECK-NEXT: %arg:_(s32) = COPY $vgpr0
    ; CHECK-NEXT: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE3 %arg
    ; CHECK-NEXT: $vgpr0 = COPY %result(s32)
    %arg:_(s32) = COPY $vgpr0
    %shiftamt:_(s32) = G_CONSTANT i32 16
    %shift:_(s32) = G_LSHR %arg, %shiftamt
    %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE1 %shift
    $vgpr0 = COPY %result
...

---
name: cvt_f32_ubyte1_lshr_24
tracksRegLiveness: true
body:             |
  bb.0:
    liveins: $vgpr0

    ; CHECK-LABEL: name: cvt_f32_ubyte1_lshr_24
    ; CHECK: liveins: $vgpr0
    ; CHECK-NEXT: {{  $}}
    ; CHECK-NEXT: %arg:_(s32) = COPY $vgpr0
    ; CHECK-NEXT: %shiftamt:_(s32) = G_CONSTANT i32 24
    ; CHECK-NEXT: %shift:_(s32) = G_LSHR %arg, %shiftamt(s32)
    ; CHECK-NEXT: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE1 %shift
    ; CHECK-NEXT: $vgpr0 = COPY %result(s32)
    %arg:_(s32) = COPY $vgpr0
    %shiftamt:_(s32) = G_CONSTANT i32 24
    %shift:_(s32) = G_LSHR %arg, %shiftamt
    %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE1 %shift
    $vgpr0 = COPY %result
...

---
name: cvt_f32_ubyte2_lshr_8
tracksRegLiveness: true
body:             |
  bb.0:
    liveins: $vgpr0

    ; CHECK-LABEL: name: cvt_f32_ubyte2_lshr_8
    ; CHECK: liveins: $vgpr0
    ; CHECK-NEXT: {{  $}}
    ; CHECK-NEXT: %arg:_(s32) = COPY $vgpr0
    ; CHECK-NEXT: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE3 %arg
    ; CHECK-NEXT: $vgpr0 = COPY %result(s32)
    %arg:_(s32) = COPY $vgpr0
    %shiftamt:_(s32) = G_CONSTANT i32 8
    %shift:_(s32) = G_LSHR %arg, %shiftamt
    %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE2 %shift
    $vgpr0 = COPY %result
...

---
name: cvt_f32_ubyte2_lshr_16
tracksRegLiveness: true
body:             |
  bb.0:
    liveins: $vgpr0

    ; CHECK-LABEL: name: cvt_f32_ubyte2_lshr_16
    ; CHECK: liveins: $vgpr0
    ; CHECK-NEXT: {{  $}}
    ; CHECK-NEXT: %arg:_(s32) = COPY $vgpr0
    ; CHECK-NEXT: %shiftamt:_(s32) = G_CONSTANT i32 16
    ; CHECK-NEXT: %shift:_(s32) = G_LSHR %arg, %shiftamt(s32)
    ; CHECK-NEXT: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE2 %shift
    ; CHECK-NEXT: $vgpr0 = COPY %result(s32)
    %arg:_(s32) = COPY $vgpr0
    %shiftamt:_(s32) = G_CONSTANT i32 16
    %shift:_(s32) = G_LSHR %arg, %shiftamt
    %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE2 %shift
    $vgpr0 = COPY %result
...

---
name: cvt_f32_ubyte2_lshr_24
tracksRegLiveness: true
body:             |
  bb.0:
    liveins: $vgpr0

    ; CHECK-LABEL: name: cvt_f32_ubyte2_lshr_24
    ; CHECK: liveins: $vgpr0
    ; CHECK-NEXT: {{  $}}
    ; CHECK-NEXT: %arg:_(s32) = COPY $vgpr0
    ; CHECK-NEXT: %shiftamt:_(s32) = G_CONSTANT i32 24
    ; CHECK-NEXT: %shift:_(s32) = G_LSHR %arg, %shiftamt(s32)
    ; CHECK-NEXT: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE2 %shift
    ; CHECK-NEXT: $vgpr0 = COPY %result(s32)
    %arg:_(s32) = COPY $vgpr0
    %shiftamt:_(s32) = G_CONSTANT i32 24
    %shift:_(s32) = G_LSHR %arg, %shiftamt
    %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE2 %shift
    $vgpr0 = COPY %result
...

---
name: cvt_f32_ubyte3_lshr_8
tracksRegLiveness: true
body:             |
  bb.0:
    liveins: $vgpr0

    ; CHECK-LABEL: name: cvt_f32_ubyte3_lshr_8
    ; CHECK: liveins: $vgpr0
    ; CHECK-NEXT: {{  $}}
    ; CHECK-NEXT: %arg:_(s32) = COPY $vgpr0
    ; CHECK-NEXT: %shiftamt:_(s32) = G_CONSTANT i32 8
    ; CHECK-NEXT: %shift:_(s32) = G_LSHR %arg, %shiftamt(s32)
    ; CHECK-NEXT: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE3 %shift
    ; CHECK-NEXT: $vgpr0 = COPY %result(s32)
    %arg:_(s32) = COPY $vgpr0
    %shiftamt:_(s32) = G_CONSTANT i32 8
    %shift:_(s32) = G_LSHR %arg, %shiftamt
    %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE3 %shift
    $vgpr0 = COPY %result
...

---
name: cvt_f32_ubyte0_zext_lshr_8
tracksRegLiveness: true
body:             |
  bb.0:
    liveins: $vgpr0

    ; CHECK-LABEL: name: cvt_f32_ubyte0_zext_lshr_8
    ; CHECK: liveins: $vgpr0
    ; CHECK-NEXT: {{  $}}
    ; CHECK-NEXT: %arg:_(s32) = COPY $vgpr0
    ; CHECK-NEXT: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE1 %arg
    ; CHECK-NEXT: $vgpr0 = COPY %result(s32)
    %arg:_(s32) = COPY $vgpr0
    %trunc:_(s16) = G_TRUNC %arg
    %shiftamt:_(s32) = G_CONSTANT i32 8
    %shift:_(s16) = G_LSHR %trunc, %shiftamt
    %zext:_(s32) = G_ZEXT %shift
    %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE0 %zext
    $vgpr0 = COPY %result
...

---
name: cvt_f32_ubyte0_zext_lshr_16
tracksRegLiveness: true
body:             |
  bb.0:
    liveins: $vgpr0

    ; CHECK-LABEL: name: cvt_f32_ubyte0_zext_lshr_16
    ; CHECK: liveins: $vgpr0
    ; CHECK-NEXT: {{  $}}
    ; CHECK-NEXT: %shift:_(s16) = G_IMPLICIT_DEF
    ; CHECK-NEXT: %zext:_(s32) = G_ZEXT %shift(s16)
    ; CHECK-NEXT: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE0 %zext
    ; CHECK-NEXT: $vgpr0 = COPY %result(s32)
    %arg:_(s32) = COPY $vgpr0
    %trunc:_(s16) = G_TRUNC %arg
    %shiftamt:_(s32) = G_CONSTANT i32 16
    %shift:_(s16) = G_LSHR %trunc, %shiftamt
    %zext:_(s32) = G_ZEXT %shift
    %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE0 %zext
    $vgpr0 = COPY %result
...

---
name: cvt_f32_ubyte0_zext_lshr_24
tracksRegLiveness: true
body:             |
  bb.0:
    liveins: $vgpr0

    ; CHECK-LABEL: name: cvt_f32_ubyte0_zext_lshr_24
    ; CHECK: liveins: $vgpr0
    ; CHECK-NEXT: {{  $}}
    ; CHECK-NEXT: %shift:_(s16) = G_IMPLICIT_DEF
    ; CHECK-NEXT: %zext:_(s32) = G_ZEXT %shift(s16)
    ; CHECK-NEXT: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE0 %zext
    ; CHECK-NEXT: $vgpr0 = COPY %result(s32)
    %arg:_(s32) = COPY $vgpr0
    %trunc:_(s16) = G_TRUNC %arg
    %shiftamt:_(s32) = G_CONSTANT i32 24
    %shift:_(s16) = G_LSHR %trunc, %shiftamt
    %zext:_(s32) = G_ZEXT %shift
    %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE0 %zext
    $vgpr0 = COPY %result
...

---
name: cvt_f32_ubyte1_zext_lshr_8
tracksRegLiveness: true
body:             |
  bb.0:
    liveins: $vgpr0

    ; CHECK-LABEL: name: cvt_f32_ubyte1_zext_lshr_8
    ; CHECK: liveins: $vgpr0
    ; CHECK-NEXT: {{  $}}
    ; CHECK-NEXT: %arg:_(s32) = COPY $vgpr0
    ; CHECK-NEXT: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE2 %arg
    ; CHECK-NEXT: $vgpr0 = COPY %result(s32)
    %arg:_(s32) = COPY $vgpr0
    %trunc:_(s16) = G_TRUNC %arg
    %shiftamt:_(s32) = G_CONSTANT i32 8
    %shift:_(s16) = G_LSHR %trunc, %shiftamt
    %zext:_(s32) = G_ZEXT %shift
    %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE1 %zext
    $vgpr0 = COPY %result
...

---
name: cvt_f32_ubyte0_shl_8
tracksRegLiveness: true
body:             |
  bb.0:
    liveins: $vgpr0

    ; CHECK-LABEL: name: cvt_f32_ubyte0_shl_8
    ; CHECK: liveins: $vgpr0
    ; CHECK-NEXT: {{  $}}
    ; CHECK-NEXT: %arg:_(s32) = COPY $vgpr0
    ; CHECK-NEXT: %shiftamt:_(s32) = G_CONSTANT i32 8
    ; CHECK-NEXT: %shift:_(s32) = G_SHL %arg, %shiftamt(s32)
    ; CHECK-NEXT: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE0 %shift
    ; CHECK-NEXT: $vgpr0 = COPY %result(s32)
    %arg:_(s32) = COPY $vgpr0
    %shiftamt:_(s32) = G_CONSTANT i32 8
    %shift:_(s32) = G_SHL %arg, %shiftamt
    %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE0 %shift
    $vgpr0 = COPY %result
...

---
name: cvt_f32_ubyte1_shl_8
tracksRegLiveness: true
body:             |
  bb.0:
    liveins: $vgpr0

    ; CHECK-LABEL: name: cvt_f32_ubyte1_shl_8
    ; CHECK: liveins: $vgpr0
    ; CHECK-NEXT: {{  $}}
    ; CHECK-NEXT: %arg:_(s32) = COPY $vgpr0
    ; CHECK-NEXT: %shiftamt:_(s32) = G_CONSTANT i32 8
    ; CHECK-NEXT: %shift:_(s32) = G_SHL %arg, %shiftamt(s32)
    ; CHECK-NEXT: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE1 %shift
    ; CHECK-NEXT: $vgpr0 = COPY %result(s32)
    %arg:_(s32) = COPY $vgpr0
    %shiftamt:_(s32) = G_CONSTANT i32 8
    %shift:_(s32) = G_SHL %arg, %shiftamt
    %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE1 %shift
    $vgpr0 = COPY %result
...

---
name: cvt_f32_ubyte2_shl_8
tracksRegLiveness: true
body:             |
  bb.0:
    liveins: $vgpr0

    ; CHECK-LABEL: name: cvt_f32_ubyte2_shl_8
    ; CHECK: liveins: $vgpr0
    ; CHECK-NEXT: {{  $}}
    ; CHECK-NEXT: %arg:_(s32) = COPY $vgpr0
    ; CHECK-NEXT: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE1 %arg
    ; CHECK-NEXT: $vgpr0 = COPY %result(s32)
    %arg:_(s32) = COPY $vgpr0
    %shiftamt:_(s32) = G_CONSTANT i32 8
    %shift:_(s32) = G_SHL %arg, %shiftamt
    %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE2 %shift
    $vgpr0 = COPY %result
...

---
name: cvt_f32_ubyte3_shl_8
tracksRegLiveness: true
body:             |
  bb.0:
    liveins: $vgpr0

    ; CHECK-LABEL: name: cvt_f32_ubyte3_shl_8
    ; CHECK: liveins: $vgpr0
    ; CHECK-NEXT: {{  $}}
    ; CHECK-NEXT: %arg:_(s32) = COPY $vgpr0
    ; CHECK-NEXT: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE2 %arg
    ; CHECK-NEXT: $vgpr0 = COPY %result(s32)
    %arg:_(s32) = COPY $vgpr0
    %shiftamt:_(s32) = G_CONSTANT i32 8
    %shift:_(s32) = G_SHL %arg, %shiftamt
    %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE3 %shift
    $vgpr0 = COPY %result
...

---
name: cvt_f32_ubyte0_shl_16
tracksRegLiveness: true
body:             |
  bb.0:
    liveins: $vgpr0

    ; CHECK-LABEL: name: cvt_f32_ubyte0_shl_16
    ; CHECK: liveins: $vgpr0
    ; CHECK-NEXT: {{  $}}
    ; CHECK-NEXT: %arg:_(s32) = COPY $vgpr0
    ; CHECK-NEXT: %shiftamt:_(s32) = G_CONSTANT i32 16
    ; CHECK-NEXT: %shift:_(s32) = G_SHL %arg, %shiftamt(s32)
    ; CHECK-NEXT: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE0 %shift
    ; CHECK-NEXT: $vgpr0 = COPY %result(s32)
    %arg:_(s32) = COPY $vgpr0
    %shiftamt:_(s32) = G_CONSTANT i32 16
    %shift:_(s32) = G_SHL %arg, %shiftamt
    %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE0 %shift
    $vgpr0 = COPY %result
...

---
name: cvt_f32_ubyte1_shl_16
tracksRegLiveness: true
body:             |
  bb.0:
    liveins: $vgpr0

    ; CHECK-LABEL: name: cvt_f32_ubyte1_shl_16
    ; CHECK: liveins: $vgpr0
    ; CHECK-NEXT: {{  $}}
    ; CHECK-NEXT: %arg:_(s32) = COPY $vgpr0
    ; CHECK-NEXT: %shiftamt:_(s32) = G_CONSTANT i32 16
    ; CHECK-NEXT: %shift:_(s32) = G_SHL %arg, %shiftamt(s32)
    ; CHECK-NEXT: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE1 %shift
    ; CHECK-NEXT: $vgpr0 = COPY %result(s32)
    %arg:_(s32) = COPY $vgpr0
    %shiftamt:_(s32) = G_CONSTANT i32 16
    %shift:_(s32) = G_SHL %arg, %shiftamt
    %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE1 %shift
    $vgpr0 = COPY %result
...

---
name: cvt_f32_ubyte2_shl_16
tracksRegLiveness: true
body:             |
  bb.0:
    liveins: $vgpr0

    ; CHECK-LABEL: name: cvt_f32_ubyte2_shl_16
    ; CHECK: liveins: $vgpr0
    ; CHECK-NEXT: {{  $}}
    ; CHECK-NEXT: %arg:_(s32) = COPY $vgpr0
    ; CHECK-NEXT: %shiftamt:_(s32) = G_CONSTANT i32 16
    ; CHECK-NEXT: %shift:_(s32) = G_SHL %arg, %shiftamt(s32)
    ; CHECK-NEXT: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE2 %shift
    ; CHECK-NEXT: $vgpr0 = COPY %result(s32)
    %arg:_(s32) = COPY $vgpr0
    %shiftamt:_(s32) = G_CONSTANT i32 16
    %shift:_(s32) = G_SHL %arg, %shiftamt
    %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE2 %shift
    $vgpr0 = COPY %result
...

---
name: cvt_f32_ubyte3_shl_16
tracksRegLiveness: true
body:             |
  bb.0:
    liveins: $vgpr0

    ; CHECK-LABEL: name: cvt_f32_ubyte3_shl_16
    ; CHECK: liveins: $vgpr0
    ; CHECK-NEXT: {{  $}}
    ; CHECK-NEXT: %arg:_(s32) = COPY $vgpr0
    ; CHECK-NEXT: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE1 %arg
    ; CHECK-NEXT: $vgpr0 = COPY %result(s32)
    %arg:_(s32) = COPY $vgpr0
    %shiftamt:_(s32) = G_CONSTANT i32 16
    %shift:_(s32) = G_SHL %arg, %shiftamt
    %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE3 %shift
    $vgpr0 = COPY %result
...

---
name: cvt_f32_ubyte0_shl_24
tracksRegLiveness: true
body:             |
  bb.0:
    liveins: $vgpr0

    ; CHECK-LABEL: name: cvt_f32_ubyte0_shl_24
    ; CHECK: liveins: $vgpr0
    ; CHECK-NEXT: {{  $}}
    ; CHECK-NEXT: %arg:_(s32) = COPY $vgpr0
    ; CHECK-NEXT: %shiftamt:_(s32) = G_CONSTANT i32 24
    ; CHECK-NEXT: %shift:_(s32) = G_SHL %arg, %shiftamt(s32)
    ; CHECK-NEXT: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE0 %shift
    ; CHECK-NEXT: $vgpr0 = COPY %result(s32)
    %arg:_(s32) = COPY $vgpr0
    %shiftamt:_(s32) = G_CONSTANT i32 24
    %shift:_(s32) = G_SHL %arg, %shiftamt
    %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE0 %shift
    $vgpr0 = COPY %result
...

---
name: cvt_f32_ubyte1_shl_24
tracksRegLiveness: true
body:             |
  bb.0:
    liveins: $vgpr0

    ; CHECK-LABEL: name: cvt_f32_ubyte1_shl_24
    ; CHECK: liveins: $vgpr0
    ; CHECK-NEXT: {{  $}}
    ; CHECK-NEXT: %arg:_(s32) = COPY $vgpr0
    ; CHECK-NEXT: %shiftamt:_(s32) = G_CONSTANT i32 24
    ; CHECK-NEXT: %shift:_(s32) = G_SHL %arg, %shiftamt(s32)
    ; CHECK-NEXT: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE1 %shift
    ; CHECK-NEXT: $vgpr0 = COPY %result(s32)
    %arg:_(s32) = COPY $vgpr0
    %shiftamt:_(s32) = G_CONSTANT i32 24
    %shift:_(s32) = G_SHL %arg, %shiftamt
    %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE1 %shift
    $vgpr0 = COPY %result
...

---
name: cvt_f32_ubyte2_shl_24
tracksRegLiveness: true
body:             |
  bb.0:
    liveins: $vgpr0

    ; CHECK-LABEL: name: cvt_f32_ubyte2_shl_24
    ; CHECK: liveins: $vgpr0
    ; CHECK-NEXT: {{  $}}
    ; CHECK-NEXT: %arg:_(s32) = COPY $vgpr0
    ; CHECK-NEXT: %shiftamt:_(s32) = G_CONSTANT i32 24
    ; CHECK-NEXT: %shift:_(s32) = G_SHL %arg, %shiftamt(s32)
    ; CHECK-NEXT: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE2 %shift
    ; CHECK-NEXT: $vgpr0 = COPY %result(s32)
    %arg:_(s32) = COPY $vgpr0
    %shiftamt:_(s32) = G_CONSTANT i32 24
    %shift:_(s32) = G_SHL %arg, %shiftamt
    %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE2 %shift
    $vgpr0 = COPY %result
...

---
name: cvt_f32_ubyte3_shl_24
tracksRegLiveness: true
body:             |
  bb.0:
    liveins: $vgpr0

    ; CHECK-LABEL: name: cvt_f32_ubyte3_shl_24
    ; CHECK: liveins: $vgpr0
    ; CHECK-NEXT: {{  $}}
    ; CHECK-NEXT: %arg:_(s32) = COPY $vgpr0
    ; CHECK-NEXT: %shiftamt:_(s32) = G_CONSTANT i32 24
    ; CHECK-NEXT: %shift:_(s32) = G_SHL %arg, %shiftamt(s32)
    ; CHECK-NEXT: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE3 %shift
    ; CHECK-NEXT: $vgpr0 = COPY %result(s32)
    %arg:_(s32) = COPY $vgpr0
    %shiftamt:_(s32) = G_CONSTANT i32 24
    %shift:_(s32) = G_SHL %arg, %shiftamt
    %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE3 %shift
    $vgpr0 = COPY %result
...

# Shift amount is wrong
---
name: cvt_f32_ubyte1_shl_7
tracksRegLiveness: true
body:             |
  bb.0:
    liveins: $vgpr0

    ; CHECK-LABEL: name: cvt_f32_ubyte1_shl_7
    ; CHECK: liveins: $vgpr0
    ; CHECK-NEXT: {{  $}}
    ; CHECK-NEXT: %arg:_(s32) = COPY $vgpr0
    ; CHECK-NEXT: %shiftamt:_(s32) = G_CONSTANT i32 7
    ; CHECK-NEXT: %shift:_(s32) = G_SHL %arg, %shiftamt(s32)
    ; CHECK-NEXT: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE1 %shift
    ; CHECK-NEXT: $vgpr0 = COPY %result(s32)
    %arg:_(s32) = COPY $vgpr0
    %shiftamt:_(s32) = G_CONSTANT i32 7
    %shift:_(s32) = G_SHL %arg, %shiftamt
    %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE1 %shift
    $vgpr0 = COPY %result
...

---
name: cvt_f32_ubyte3_shl_17
tracksRegLiveness: true
body:             |
  bb.0:
    liveins: $vgpr0

    ; CHECK-LABEL: name: cvt_f32_ubyte3_shl_17
    ; CHECK: liveins: $vgpr0
    ; CHECK-NEXT: {{  $}}
    ; CHECK-NEXT: %arg:_(s32) = COPY $vgpr0
    ; CHECK-NEXT: %shiftamt:_(s32) = G_CONSTANT i32 17
    ; CHECK-NEXT: %shift:_(s32) = G_SHL %arg, %shiftamt(s32)
    ; CHECK-NEXT: %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE3 %shift
    ; CHECK-NEXT: $vgpr0 = COPY %result(s32)
    %arg:_(s32) = COPY $vgpr0
    %shiftamt:_(s32) = G_CONSTANT i32 17
    %shift:_(s32) = G_SHL %arg, %shiftamt
    %result:_(s32) = G_AMDGPU_CVT_F32_UBYTE3 %shift
    $vgpr0 = COPY %result
...
